

A

  
Jc586 U.S. PRO  
09/431417  
11/01/99

**IN THE UNITED STATES PATENT AND TRADEMARK OFFICE**

Patent Application of: Kiran Ganesh et al.

Title: 2-DIMENSIONAL PLACEMENT WITH RELIABILITY CONSTRAINTS FOR VLSI DESIGN

Attorney Docket No.: 884.141US1

**PATENT APPLICATION TRANSMITTAL**

**BOX PATENT APPLICATION**

Assistant Commissioner for Patents  
Washington, D.C. 20231

We are transmitting herewith the following attached items and information (as indicated with an "X"):

- Utility Patent Application under 37 CFR § 1.53(b) comprising:  
 Specification ( 30 pgs, including claims numbered 1 through 31 and a 1 page Abstract).  
 Formal Drawing(s) ( 14 sheets).  
 Unsigned Combined Declaration and Power of Attorney ( 4 pgs).  
Information Disclosure Statement ( 1 pgs), Form 1449 ( 2 pgs), and copies of cited references ( 13 ).  
Return postcard.

The filing fee (NOT ENCLOSED) will be calculated as follows:

|                                         | No. Filed | No. Extra | Rate   | Fee               |
|-----------------------------------------|-----------|-----------|--------|-------------------|
| TOTAL CLAIMS                            | 31 - 20 = | 11        | x 18 = | \$198.00          |
| INDEPENDENT CLAIMS                      | 7 - 3 =   | 4         | x 78 = | \$312.00          |
| [ ] MULTIPLE DEPENDENT CLAIMS PRESENTED |           |           |        | \$0.00            |
| BASIC FEE                               |           |           |        | \$760.00          |
|                                         |           |           |        | <b>\$1,270.00</b> |

**THE FILING FEE WILL BE PAID UPON RECEIPT OF THE NOTICE TO FILE MISSING PARTS.**

SCHWEGMAN, LUNDBERG, WOESSNER & KLUTH, P.A.  
P.O. Box 2938, Minneapolis, MN 55402 (612-373-6900)

By: Ann M. McCrackin  
Atty: Ann M. McCrackin  
Reg. No. 42,858

**Customer Number 21186**

"Express Mail" mailing label number: EL530191347US

Date of Deposit: November 1, 1999  
I hereby certify that this paper or fee is being deposited with the United States Postal Service "Express Mail Post Office to Addressee" service under 37 CFR 1.10 on the date indicated above and is addressed to the Assistant Commissioner for Patents, Box Patent Application, Washington, D.C. 20231.

By: Chris Hammond

Signature: Chris Hammond

UNITED STATES PATENT APPLICATION

**2-Dimensional Placement With Reliability Constraints for VLSI Design**

**INVENTORS**

**Kiran Ganesh**

resident of Mountain View, CA  
citizen of India

**Artour Levin**

resident of San Jose, CA  
citizen of Belarus

**Miles F. McCoo**

resident of Haifa, Israel  
citizen of United States

**Naresh K. Sehgal**

resident of Santa Clara, CA  
Citizen of United States

Schwegman, Lundberg, Woessner, & Kluth, P.A.  
1600 TCF Tower  
121 South Eighth Street  
Minneapolis, Minnesota 55402  
ATTORNEY DOCKET SLWK 884.141US1  
Client Reference P6788

## Field of the Invention

The present invention is related to computer-aided design, and more particularly to a computer-aided design placement tool for performing 2-dimensional transistor placement with emphasis on reliability verification constraints in integrated circuit layout.

## Background Information

Integrated circuits comprise a collection of components, including but not limited to transistors, resistors, and capacitors, fabricated on a semiconductor substrate. The components are connected with metal interconnections, called wires, to form a system such as a microprocessor. Integrated circuit performance has been improving because the components and the wires are being fabricated in smaller sizes to increase the density of the integrated circuits. However, keeping the correct functionality of an integrated circuit intact over extended periods of usage and preventing breakdowns are new concerns that designers and computer-aided design tools need to address for circuit designs.

Circuits that function properly when fabricated often fail to work after a certain period of use. Such failures are caused by various reliability phenomena. Electromigration is a common reliability phenomenon that affects high-frequency circuits today. Electromigration refers to the migration of metal ions due to prolonged electron flow in the *same* direction. Electromigration causes progressive damage to metal conductors in an integrated circuit. Electromigration results in the creation of voids and hillocks in the metal interconnections, as a result of which the effective cross-section of the conductor comes down. Over time, the metal width of the interconnection is no longer sufficient to carry the current and this causes electrical opens or increased resistance which lead to circuit failure. FIGS. 1A and 1B are diagrams of a top view of a wire illustrating the effects of electromigration. As shown in FIG. 1A, a wire unaffected by electromigration has a uniform width.

However, a wire having a high unidirectional current density experiences electromigration over a period of use. As shown in FIG. 1B, the width of the wire is no longer uniform due to electromigration.

Another reliability phenomenon is the self-heat of metal wires. Self-heat refers 5 to the thermal breakdown of a conductor, very similar to how a filament in a bulb burns out. FIGS. 2A and 2B are diagrams of a top view of a wire illustrating the effects of self-heat. As shown in FIG. 2A, a wire unaffected by self-heat has a uniform width. However, a wire having a high density current experiences self-heat over a period of use. As shown in FIG. 2B, a wire affected by self-heat breaks down 10 and is no longer uniform.

Both of these problems are caused by large currents in interconnections that are not wide enough to handle them. In any modern high-frequency integrated circuit, interconnections have to be sized based on these reliability concerns. With 15 microprocessor designs now entering the GHz frequency ranges, it is extremely critical to optimize their design layouts for reliability verification (RV) constraints. But optimizing layouts by hand for reliability verification constraints affects a mask-designer's productivity because the amount of layout rework involved can be quite significant. However, currently available automated placement algorithms do not consider reliability verification issues.

20 Accordingly, there is a need for an automated design tool that minimizes reliability concerns arising from electromigration and self heat, while at the same time achieves a high layout density.

### **Summary of the Invention**

25 According to one embodiment of the present invention, a computerized method of creating a layout for a circuit design includes receiving a circuit design and receiving at least one layout rule based on a reliability verification constraint for the circuit design. The computerized method further includes generating a layout for the circuit design through computer automated operations wherein the layout generated

satisfies the at least one layout rule based on the reliability verification constraint received for the circuit design.

Other embodiments are described and claimed.

5

### Brief Description of the Drawings

FIGS. 1A and 1B are diagrams of a top view of a wire illustrating the effects of electromigration.

FIGS. 2A and 2B are diagrams of a top view of a wire illustrating the effects of self-heat.

10 FIG. 3 is a diagram of a typical hardware and operating environment in conjunction with which embodiments of the invention may be implemented.

FIG. 4 is a block diagram of one embodiment of a computer automated placement tool of the present invention.

15 FIG. 5 is a high level flowchart of a method of placing components of an integrated circuit in a layout according to one embodiment of the present invention.

FIG. 6 is a more detailed flow chart of the “Cluster the components. . .” block of FIG. 5 according to one embodiment of the present invention.

FIGS. 7A, 7B, 7C, 7D, 7E and 7F are schematic diagrams of transistors in a cluster used to illustrate various folding schemes.

20 FIG. 7G is a diagram of the physical layout for the schematic in FIG. 7F.

FIG. 8 is a more detailed flow chart of the “Generate a layout. . .” block of FIG. 5 according to one embodiment of the present invention.

FIG. 9 is a diagram of a cluster of transistors generated according to block 502 of FIG. 5.

25 FIGS. 10A and 10B are structural trees for the N- and P-parts of the cluster shown in FIG. 9.

FIG. 11A is a diffusion graph for the P-parts of the cluster shown in FIG. 9.

FIG. 11B is the diffusion graph of FIG. 11A with arrows on the edges to indicate a path.

30 FIGS. 12A, 12B and 12C are diagrams of the P-part and the N-part of a cluster.

FIG. 13 is a more detailed flow chart of the “Place the various layout clusters . . .” block of FIG. 5 according to one embodiment of the present invention.

FIG. 14 is a block diagram of a 2-dimensional layout space having overlapping rows according to one embodiment of the invention.

5 FIG. 15 is a diagram of a circuit segment used to illustrate an example method of computing an electromigration cost function.

FIG. 16 is a diagram of transistors used to illustrate an example of terminal blockage.

10

## Description of the Preferred Embodiments

In the following detailed description of the preferred embodiments, reference is made to the accompanying drawings which form a part hereof, and in which is shown by way of illustration specific embodiments in which the invention may be practiced. It is to be understood that other embodiments may be utilized and 15 structural changes may be made without departing from the scope of the present invention.

The embodiments of a novel 2-dimensional placement system and method described below minimize reliability concerns arising from electromigration and self-heat while at the same time achieving a high layout density. In one embodiment, 20 the 2-dimensional placement method is useful in placing circuits containing widely varying transistor sizes. Some embodiments of the present invention are used for synthesis of standard cells, datapath bit-cells or custom cells.

The phrase “some embodiments” refers to at least some embodiments of the invention. The various appearances of “some embodiments” are not necessarily referring to the same embodiments. If the specification states a component, feature, structure, or characteristic “may,” “might,” or “could” be included, that particular component, feature, structure, or characteristic is not required to be included. Reference in the specification to “an embodiment” or “one embodiment” means that 25 a particular feature, structure, or characteristic described in connection with the

embodiment is included in at least some embodiments, but not necessarily all embodiments, of the invention.

## **Hardware and Operating Environment**

- 5 FIG. 3 is a diagram of a typical hardware and operating environment in conjunction with which embodiments of the invention are implemented. Computer system 300 comprises a bus or other communication means 301 for communicating information, and a processor 302 coupled with bus 301 for processing information.
- 10 Computer system 300 further comprises a random access memory (RAM) or other dynamic storage device 304 (referred to as main memory), coupled to bus 301 for storing information and instructions to be executed by processor 302. Main memory 304 also may be used for storing temporary variables or other intermediate information during execution of automated placement tool instructions by processor 302. Computer system 300 also comprises a read only memory (ROM) and/or other
- 15 static storage device 306 coupled to bus 301 for storing static information and instructions for processor 302, and a data storage device 307 such as a magnetic disk or optical disk and its corresponding disk drive. Data storage device 307 is coupled to bus 301 for storing information and instructions for creating a layout for a circuit design. Computer system 300 may further be coupled to a display device 321, such
- 20 as a cathode ray tube (CRT) or liquid crystal display (LCD) coupled to bus 301 for displaying design placement information to a computer user. An alphanumeric input device 322, including alphanumeric and other keys, may also be coupled to bus 301 for communicating information and command selections to processor 302. An additional user input device may be cursor control device 323, such as a mouse,
- 25 trackball, stylus, or cursor direction keys, coupled to bus 301 for communicating direction information and command selections to processor 302, and for controlling cursor movement on display 321. Another device which may be coupled to bus 301 is hard copy device 324 which may be used for printing instructions, data, or other information on a medium such as paper, film, or similar types of media. Note, also,
- 30 that any or all of the components of computer system 300 and associated hardware

may be used in one embodiment, however, it can be appreciated that any type of configuration of the system may be used for various purposes as the user requires in other embodiments.

Computer-readable instructions stored on a computer-readable medium are executable by the processor 302 of computer system 300. A hard drive, CD-ROM, and RAM are some examples of articles including a computer-readable medium. For example, a computer-aided design tool performing reliability verification may be included on a CD-ROM and loaded from the CD-ROM to a hard drive. The computer-readable instructions cause the computer system 300 to perform methods of creating a layout for a circuit design as further described below.

### System Level Overview

Computer-aided design tools are used to automated the design of integrated circuits. Several different types of computer-aided design tools are available, including but not limited to, schematic design tools, net list tools, placement tools and routing tools. A placement tool is used to locate the components of a circuit design for an integrated circuit in a physical layout for the integrated circuit. The placement tool receives as input the circuit design and various layout architecture rules and produces layouts that conform to those rules. The novel placement tool of the present invention receives at least one layout rule based on reliability verification constraints and generates a layout that conforms to the layout rules.

Reliability verification constraints refer to constraints arising from any phenomena that lead to the gradual malfunctioning of a chip. Such phenomena cause chips that function properly when manufactured to develop problems over certain periods of usage. Two examples of such phenomena are electromigration and self-heat.

A system level overview of one embodiment of the present invention is described by reference to Fig. 4. Fig. 4 is a block diagram of a computer automated placement system 400. The computer automated placement system shown in Fig. 4 comprises inputs 402, processing modules 404, and one or more outputs 406.

In one embodiment, the inputs 402 comprise a circuit design for an integrated circuit and one or more layout rules based on reliability verification constraints. The circuit design is created using any commonly available schematic design tool software. A net list representation of the circuit design is created using any  
5 commonly available net list tool software.

In one embodiment, a cell library maintains a plurality of gates and a plurality of layout rules for the circuit design and at least one of the layout rules is based on a reliability verification constraint. One example of a layout rule based on a reliability verification constraint is the specification of a maximum current that a wire of a  
10 given width can carry based on electromigration constraints. Another example of such a rule is the specification of a maximum current density for a wire of a given width due to self-heat constraints. These rules are specified for one or more of the metal layers available for interconnection. Alternate embodiments having additional or differing layout rules are contemplated as within the scope of the invention. For  
15 example, some embodiments have layout rules based on other reliability phenomena such as thermal cracking of polysilicon, latch-up issues and maximum current per contact. Likewise, some embodiments have additional layout rules based on traditional layout constraints such as density constraints, aspect ratio constraints, or routing complexity constraints.

20 The processing modules 404 comprise program modules that perform the functions of a computer automated placement tool. Generally, program modules include routines, programs, objects, components, data structures, etc., that perform particular functions or implement particular abstract data types. In one embodiment, the processing modules 404 receive the circuit design in the form of a net list. The  
25 processing modules place the components of the circuit design in a layout and the processing modules analyze the placement for compliance with the layout rules based on reliability verification constraints. One output 406 of the computer automated placement system 400 is a layout for the integrated circuit that complies with the layout rules based on the reliability verification constraints received as

inputs. In one embodiment, wires are routed between the plurality of gates in the layout of the integrated circuit using any commonly available routing tool software.

Additional inputs, functions of the processing modules, and outputs will be readily apparent from the following detailed description.

5

### Methods of the Invention

In the previous section, a system level overview of the operation of an example embodiment of the invention was described. In this section, the particular methods performed by a processor, such as the processor 302 of FIG. 3, in an example

- 10 embodiment are described by reference to a series of flowcharts and diagrams. The methods to be performed constitute computer programs made up of computer-executable instructions. The methods shown in FIGS. 5-16 are implemented in connection with a machine readable medium comprising machine readable instructions for causing a computer to perform the method. Such machine  
15 readable medium may include software modules and computer programs. The computer programs comprise multiple modules or objects to perform the methods, or the functions of the processing modules in the computer automated placement system of FIG. 4. The type of computer programming languages used to write the code may vary from procedural code type languages to object oriented languages.  
20 The files or objects need not have a one to one correspondence to the modules or method steps described depending on the desires of the programmer. Further, the method and apparatus may comprise combinations of software, hardware and firmware. Describing the methods by reference to flowcharts enables one skilled in the art to develop such programs including such instructions to carry out the methods  
25 on suitable computerized systems.

A major drawback of current placement methods is that the techniques focus on high layout density and ignore reliability verification (RV) constraints.

Significant redesign effort is saved by considering RV constraints during the layout of a circuit design. The novel placement methods of the present invention consider  
30 reliability verification constraints in addition to traditional metrics such as width

minimization and wiring cost. In one embodiment, the placement methods minimize reliability verification concerns arising from electromigration and self heat while simultaneously achieving a high layout density. The placement methods described in this section also make use of rows that have non-uniform sizes and are overlapping. This produces a result that is closer to manual layout than the pseudo 2-dimensional methods currently available. According to one embodiment of the present invention, the placement method consists of three main operations: (1) clustering of components, (2) generating the layouts for these clusters, and (3) placing the various layout clusters relative to each other.

FIG. 5 is a high level flowchart of a method of placing components of an integrated circuit in a layout according to one embodiment of the present invention. As shown in FIG. 5 the method begins by clustering the components of the integrated circuit (block 502). In one embodiment, clustering is performed based on an analysis of a circuit design received in the form of a net list. After clustering the components of the integrated circuit, layouts are generated for each of the clusters (block 504). Then the various layout clusters are placed relative to each other in a layout for the integrated circuit (block 506). A novel cost function is used to evaluate the resulting layout for the integrated circuit. The cost function considers reliability verification constraints and is further described below. The following sections further elaborate on blocks 502, 504 and 506 of FIG. 5.

***Clustering of the Components.*** As schematics get larger it is often desirable to break up the schematic into smaller segments to keep the complexity manageable. One method of breaking up the schematic is referred to as clustering. The purpose of clustering is to break up a schematic into a set of strongly connected transistors according to a desired gate ordering style. For any cell library, sets of layout architecture rules dictate the desired gate ordering style.

FIG. 6 is a more detailed flow chart of the “Cluster the components . . .” block of FIG. 5. As shown in FIG. 6, clustering begins by assigning each of the transistors to one of a plurality of clusters (block 602). After the transistors are assigned to clusters, the clusters are merged according to a desired gate ordering style (block

604). In some embodiments, the clusters are adjusted after they are merged (block 606). For example, the clusters may be adjusted to comply with various layout constraints or to equalize stack legs. The operations in block 604 and 606 of FIG. 6 are now described in more detail.

5 As shown in FIG. 6, after each transistor is assigned to a cluster, the clusters are merged according to a desired gate ordering style (block 604). In one embodiment, the clusters are merged based on a lumped gate ordering style or a distributed gate ordering style. However, the invention is not limited to lumped or distributed gate ordering styles. Alternate embodiments having additional or  
10 differing gate ordering styles are contemplated as within the scope of the invention.

For a lumped gate ordering style, clusters with legs from the same transistors are merged together. The lumped gate ordering style is used when the electromigration rules for the operating frequency allow abutment of transistors legs with the same gate net. Lumped gate ordering is used because it saves a significant  
15 amount of routing area for the input signals. However, in a high-frequency cell library, transistor legs with similar gate nets cannot be placed together due to electromigration from increased strap currents. However, a distributed gate ordering style is used where two abutting transistors usually do not have the same gate net.  
For a distributed placement style, the clusters are merged on a net-by-net basis. For  
20 each net except power and ground, all clusters with devices whose sources or drains connect to this net are conditionally merged. In most cases, each one of the resulting clusters obtained corresponds to a logic gate in the circuit design.

However, devices with a large size mismatch should not be merged during clustering. In one embodiment, an input parameter,  $\lambda$ , is defined to quantify this size  
25 mismatch. If the ratio of the width of device from the new cluster to the width of the largest device in the current cluster is larger than  $l$  or smaller than  $1/\lambda$ , then the two clusters should not be merged. Otherwise, the final result of placement will not be optimal since the abutment of transistors not matched in width is a potential waste of cell area. However, one exception is the transmission gate.

In some embodiments, after the clusters are merged, the clusters are adjusted (block 606). For example, the clusters may be adjusted to comply with various architecture layout rules or layout constraints. For example, fabrication processes may limit the maximum size of a device that can be manufactured reliably. In cases 5 where the schematic devices need to be larger than the size allowed by the layout constraints, transistors are folded into multiple legs to comply with the size limits.

Some examples of folding schemes are described by reference to FIGS. 7A, 7B, 7C, 7D, 7E, 7F, and 7G which are schematic diagrams or layout diagrams of transistors in a cluster. In the example embodiments shown in FIGS. 7A, 7B, 7C, 10 7D, 7E, 7F and 7G the maximum device size allowed by the layout constraints is two microns ( $2\mu$ ). The example shown in FIG. 7A is a diagram of cluster having a transistor with a width of six microns ( $6\mu$ ) and a transistor with width of three microns ( $3\mu$ ). Both devices shown in FIG. 7A exceed the maximum device size allowed for the cluster. Accordingly, the size of devices in the cluster is adjusted as 15 shown in FIG. 7B to comply with the layout constraints. In the example embodiment shown in FIG. 7B, the folding scheme applied is referred to as “device-based legging.” Device-based legging is the process by which transistors whose width exceeds the process limit are folded into smaller legs by a simple modulus operation. The modulus procedure for device-based legging is given below:

20       remainingWidth = size of given transistor  
          maxLimit = Maximum transistor size  
          placedWidth = width of each new transistor leg  
          While (remainingWidth > maxLimit) {  
            placedWidth = maxLimit;  
            remainingWidth = remainingWidth - maxLimit;  
          }  
25

While folding transistors, the algorithm also needs to make sure it is design rule correct and that the necessary add-on values (if any) for device legging are also 30 considered. Thus, in device-based legging, transistors are folded solely based on the process limit and considerations of overall circuit structure do not come into the picture at all. The example shown in FIG. 7B, illustrates a device-based legging folding scheme. As shown in FIG. 7B, the device with a width of six microns ( $6\mu$ )

(in FIG. 7A) has been folded into three legs of two microns ( $2\mu$ ) each. The device with a width of three microns ( $3\mu$ ) (in FIG. 7A) has been folded into one leg of two microns ( $2\mu$ ) and one leg of one micron ( $1\mu$ ).

- Re-legging of a device is advantageous for reasons other than complying with size constraints. For example, consider a circuit having a stack of transistors having different widths such as the circuit shown in FIG. 7A. When the transistors are placed, metal tracks have to be allocated to route the internal nodes after placement. By introducing additional device folding, the number of legs can be equalized across all stacked devices as shown in FIG. 7C. In this example, device folding eliminates the need for routing the internal nodes, and should be used whenever such a gain is estimated to be higher than the cost of folding. This scheme is referred to as “stack-based legging.” Stack-based legging refers to the folding of transistors in a way that preserves the regularity of the circuit topology. Transistors are folded not in isolation, but with consideration with respect to the overall circuit structure. This difference is illustrated by comparing FIGS. 7A, 7B and 7C. FIG. 7C preserves the regularity of the circuit structure of 7A and thus is an example of stack-based legging. In contrast, FIG. 7B does not preserve the regularity of the circuit structure of FIG. 7A since the transistors are folded in isolation and without regard to other transistors in the circuit.
- Several other layout considerations also determine how and when schematic devices should be legged before placement. In another example embodiment, the placement method of the present invention performs a scheme referred to as “differential-legging” to generate stacks of devices with notches designed for well taps, substrate taps or input pins. Differential legging refers to the process of artificially creating a small transistor during the transistor legging process. The notch created in the layout due to this small transistor can be used to insert objects (such as input pins, substrate taps, input protection diodes etc.) which otherwise may have been difficult because of lack of convenient notch area in the layout.
- The following example compares device-based legging to differential legging.
- With a process legging limit of two microns ( $2\mu$ ), a device with a width of four

microns ( $4\mu$ ) as shown in FIG. 7D is folded into two legs of two microns ( $2\mu$ ) each as shown in FIG. 7E by the device-based legging scheme. In contrast, using differential legging the same device is folded into two legs of one-and-three-fourths microns ( $1.75 \mu$ ) each and one leg of one-half micron ( $0.5 \mu$ ) as shown in FIG. 7F to 5 create a notch for taps or input pins. The smaller transistor shown in FIG. 7F creates a notch in the physical layout. The physical layout for the schematic in FIG. 7F is illustrated in FIG. 7G.

In one embodiment of the present invention, the layout production environment uses a Cell Architecture Rules Language for describing the various 10 knobs that control device legging to the placement algorithm. The Cell Architecture Rules Language is further described in B. Basaran et al., "GeneSys - A Leaf-Cell Layout Synthesis System for GHz VLSI Designs," *Proc. 12th International Conference on VLSI Design*, pp. 448-452 January 1999.

**Generation of Cluster Layouts.** A method of clustering the components of the 15 integrated circuit according to one embodiment of the present invention has been described. This section further describes a method of generating a layout for each one of the clusters as referred to in block 504 of FIG. 5.

According to conventional methods, a Euler-path technique is used for the generation of a layout from clusters of a schematic. However, the Euler-path 20 technique does not take into account reliability verification constraints when generating the layout for the cluster of the schematic. The present invention uses a novel method of generating a layout for a cluster ("cluster layout") that takes into account reliability verification constraints as well as traditional constraints such as diffusion sharing and gate ordering for a wide variety of circuit types.

The following section describes an example embodiment of a method of 25 generating a cluster layout for combinational circuit designs such as fully complementary CMOS circuits. However, the invention is not limited to layout generation for combinational circuit designs. Layout generation for other types of circuit designs such as domino and pass-gate logic are contemplated as within the 30 scope of the invention. For example, the method can be applied to domino logic by

treating the N- and P-parts independently of each other and adding noise constraints to the clustering and simulated annealing cost functions.

FIG. 8 is a more detailed flow chart of the “Generate a layout for each one of the clusters” block of FIG. 5 (block 504). As shown in FIG. 8, the method of generating a layout begins by building a structural tree representing the N- and P-parts of the cluster (block 802). The structural trees are used to build a diffusion graph for the N- and P-parts of the cluster (block 804). Methods of building the structural trees and building the diffusion graphs are known in the art. Next, the method includes finding a path in the diffusion graph (block 806). The operation of finding a path takes into consideration RV constraints and is described in more detail below. The resulting path corresponds to the order of the transistors in the layout for the cluster. A layout is generated for the cluster based on the paths (block 808). The operations shown in the flow chart of FIG. 8 are further illustrated by the following example described by reference to FIGS. 9, 10A, 10B, 11A, 11B, 12A, 12B and 12C.

FIG. 9 is as a diagram of a cluster of transistors generated according to block 502 of FIG. 5. FIGS. 10A and 10B are structural trees for the N- and P-parts of the cluster shown in FIG. 9. The structural tree,  $TP$ , shown in FIG. 10A, represents the hierarchical structure of the P-parts of the cluster shown in FIG. 9. The structural tree,  $TN$ , shown in FIG. 10B, represents the hierarchical structure of the N-parts of the cluster shown in FIG. 9. As shown in FIGS. 10A and 10B, the leaf vertices 1002, 1006 of the trees correspond to the devices in the cluster. The other vertices 1004, 1008 correspond to a connection type, either parallel (P) or series (S), of the children of the other vertices 1004, 1008. The structural trees are constructed separately for the N and P clusters. The structural trees are used for estimations of routing length and pairing corresponding P and N transistors.

In an example embodiment of the invention, the children of every vertex in the structural trees  $TP$  and  $TN$ , as shown in FIG. 10A and 10B respectively, are ordered as follows:

- a) If the vertex is a series vertex, the order of its children is the order of the corresponding devices in the stack.

b) If the vertex is a parallel vertex, then there is a dual vertex in the complementary tree which is a series vertex. The order of its children coincides with the order of the children of the dual vertex.

FIG. 11A is a diffusion graph  $DP$  for the P-parts of the cluster shown in FIG. 9. A diffusion graph  $DN$  is also created for the N-part of the cluster, but is not shown here. Each edge (i.e. line) in the diffusion graph corresponds to one of the transistors in the P-part of the cluster shown in FIG. 9. The methods of creating diffusion graphs are known in the art.

FIG. 11B is the diffusion graph  $DP$ , as shown in FIG. 11A, with arrows on the edges to indicate a path. The identified path is used to create the layout of the P-part of the cluster shown in FIG. 9. In one embodiment, the path is identified by modifying a Flery algorithm of finding a Euler path in a graph as described below. To find the path, begin by selecting an arbitrary vertex of the diffusion graph that satisfies the following criteria:

- 15      a) The vertex has the maximum odd degree.
  - b) Prefer odd-degree power node to a odd-degree non-power node.
- Odd-degree vertices are preferred since they enable traversal out of the vertex without diffusion breaks.
- 20      c) If no odd degree node exists, then prefer a power node over a non-power node. Power nodes are preferred at the outer ends to reduce signal capacitance.
  - d) The vertex does not correspond to an internal net, since such a net will have to be routed if it is on the outer edges of a cluster.

Selecting different vertices allows the generation of different layout implementations of the same cluster. After selecting an arbitrary vertex, let  $w$  be the 25 vertex of the diffusion graph that has been reached and  $k$  be the number of the last edge that has been marked (initially  $k=0$ ). Select the next edge of the diffusion graph according to the following rules:

- 30      a) Select a bridging edge only if there is no other choice.
- b) When there is a choice between multiple non-bridging edges, then use the following rules in the given precedence:

1) Select a gate net based on electromigration constraints. (An example is described below.)

2) Select an edge which will ensure the same order of P and N transistors. This information is obtained from the complementary structural tree.

5           3) Select an edge which is nearest to current node in the structural tree,  
to minimize routing requirements

The application of the novel rule of selecting a gate net based on electromigration constraints in (b)(1) above is illustrated with the following example. Consider a 4-input NAND gate cell. Let each of the input signals (a, b, c, d) connect to three legs of PMOS and NMOS transistors each. If the target frequency for the library is high enough, then the layout must be strongly driven by electromigration concerns. Therefore, to reduce strap currents, the following gate orderings will be preferable:

$(a\ b\ c\ d\ d\ c\ b\ a\ a\ b\ c\ d)$  or  $(a\ b\ c\ d\ a\ b\ c\ d\ a\ b\ c\ d)$

15 Whereas if the current values are not significant enough, as in a lower frequency library, the current values allow for lumping similar gate nets together, as in:

(*a a a b b b c c c d d d*)

An overall area reduction is possible in this case, even with potential diffusion breaks. This is because all the inputs can be routed with one metal track in most cases (assuming a single row placement for the cluster).

Depending on particular layout design style and process reliability verification constraints, the placement algorithm is able to adapt to varying requirements on gate ordering. Another common gate-ordering scheme that shares routing tracks on input signals is:

$$(a\ b\ a\ b\ a\ b\ c\ d\ c\ d\ c\ d)$$

Referring back to FIG. 11B, an example path goes through N2, N3, N2, N1, N3. This path goes through a, b, c, and d but not e due to diffusion break. Based on this path, the order of the transistors for the P-part of the cluster is a, b, c, d and e for the above example.

After generating the layouts for all clusters, some clusters can be potentially very long compared to others. In such cases, the placement of layout clusters relative to each other as described in the next section becomes easier if the long clusters are broken up into smaller chunks, as illustrated by reference to FIGS. 12A, 12B and 5 12C.

As shown in FIGS. 12A, the row for the P-part of the cluster is much longer than the row for the N-part of the cluster. In this case folding is done to equalize the size of the rows. The stacks of devices are usually allowed to split on the power and ground nets only, since the increase in nodal capacitance is generally allowed only 10 for non-switching nodes. Four possible row cutting lines are indicated in FIG. 12A. FIGS. 12B and 12C illustrate two example ways to fold the P-part of the cluster. As shown in FIG. 12B, the P-part is folded at the left and right-most VCC lines and the corresponding portions of the P-part are placed on the left and right end of the N-part. As shown in FIG. 12C, the P-part is folded at one of the VCC lines on the 15 left side and the corresponding portion of the P-part is placed on the left end of the N-part.

**Placement of Cluster Blocks.** A method of generating a layout for each one of the clusters according to one embodiment of the present invention has been described. This section further describes a method of placing the various layout 20 clusters relative to each other as referred to in block 506 of FIG. 5.

Once the various clusters have been generated and a layout produced for each cluster according to block 502 and block 504 of FIG. 5, an iterative improvement technique is used to place the clusters relative to each other. In one embodiment, while placing the clusters relative to each other, the novel placement method of the 25 present invention address the following concerns: (1) reduction of current density to minimize RV problems and (2) packing of the clusters in a true 2-dimensional manner.

FIG. 13 is a more detailed flowchart of the “Place the various layout clusters relative to each other” block of FIG. 5 (block 506). As shown in FIG. 13, the method 30 begins by placing the various layout clusters in a layout for the integrated circuit

(block 1302). In one embodiment, the layout is performed in a 2-dimensional manner as further described below. Then, the reliability verification constraints are analyzed for the layout of the integrated circuit (block 1304). In one embodiment, the analysis includes calculating a cost function having a reliability verification

5 factor representing the effects of self-heat and electromigration. One objective of the method shown in FIG. 13 is to minimize such a cost function and thus minimize reliability verification concerns arising from electromigration and self heat. To further minimize the cost function and improve the final layout, the layout clusters may be rearranged (block 1306). Perturbation functions used to rearrange the layout  
10 are further described below. In one embodiment, the process shown in block 1304 and block 1306 is repeated until the cost function has been minimized as desired (block 1308). In some embodiments, the layout is also analyzed at block 1304 for traditional constraints such as layout density constraints, aspect ratio constraints, and routing complexity constraints.

15 In one embodiment, the operations of placing the clusters (block 1302 of FIG. 13) and rearranging the clusters (block 1306 of FIG. 13) are performed in a 2-dimensional manner. The novel cluster placement method of the present invention models uses multiple overlapping rows to guide the placement of the clusters in a 2-dimensional manner. The row widths are generated based on the widths of the  
20 clusters. There are several ways of breaking an area, or placement space, into multiple overlapping rows. An example embodiment uses the width of the smallest cluster to partition the entire cell width into rows that have widths which are integer multiples of this width.

FIG. 14 is a block diagram of a 2-dimensional layout space having overlapping  
25 rows according to one embodiment of the invention. The width (w) of the rows in the layout shown in FIG. 14 are multiples of the width of the smallest cluster 1402. The layout space shown in FIG. 14 has ten rows comprised of four rows of width W (row A, row B, row C, row D), three rows of width 2W (row AB, row BC, row CD), two rows of width 3W (row ABC, row BCD) and one row of width 4W (row

ABCD). Such an overlapping scheme of rows allows a dense placement of clusters that are mismatched in their widths

In one embodiment, the operations shown in FIG. 13 are implemented with a simulated annealing algorithm such as the following example simulated annealing

5 algorithm:

```
1   temp = INIT_TEMP
2   place = INIT_PLACEMENT
3   while (temp > FINAL_TEMP) do {
10  4   while (inner_loop_criterion = FALSE) do {
5       new_place = PERTURB(place)
6       ΔC = COST(new_place) - COST(place)
7       if (ΔC<0 or RANDOM(0,1) > e^ΔCT) then
8           place = new_place;
15  9       temp = SCHEDULE(temp);
10      }
11  }
```

Previous cluster placement algorithms using simulated annealing focused on  
20 optimizing diffusion gaps and wire lengths. In contrast, reliability verification  
constraints are analyzed with a novel simulated annealing cost function of the present  
invention in addition to traditional metrics such as cell area, wire-length and number  
of diffusion breaks. In one embodiment of the present invention, the simulated  
annealing cost function is set up to bias the topology towards a gate ordering that  
25 minimizes overall current density and thus reduces the effects over time of reliability  
phenomena such as electromigration and self heat.

In an example embodiment, the simulated annealing cost function is selected  
such that it optimizes all the variables of interest. According to one embodiment of  
the present invention, the structure of the cost function used is as follows:

$$30 \quad Cost\ function = k_{CA}F_{CA} + k_{WL}F_{WL} + k_{DB}F_{DB} + k_{RV}F_{RV} + k_{TB}F_{TB}$$

The cost function is a weighted sum of five different components. The example cost function provided above includes traditional metrics such as cell area ( $F_{CA}$ ), wire-length estimation ( $F_{WL}$ ) and the number of diffusion breaks ( $F_{DB}$ ). The example cost function defined above also includes two new and useful measures of quality, namely, RV constraints ( $F_{RV}$ ) and terminal blockage estimation ( $F_{TB}$ ).

The success of a simulated annealing cost function is influenced by the selection of the weights ( $k_{CA}$ ,  $k_{WL}$ ,  $k_{DB}$ ,  $k_{RV}$  and  $k_{TB}$ ) that normalize the five cost components. A variety of factors determine the selection of weights in the simulated annealing cost function. In one embodiment, if the layout architecture is heavily driven by reliability constraints, then the reliability weights are increased relatively to reflect this. In another embodiment, the desired layout architecture is studied and several representative cells are passed through this algorithm. The initial weights are determined by theoretical calculations, and then the weights are adjusted using the experimental data obtained from the representative cells. Such experimentation can produce several sets of weight factors, each of which are categorized as being useful for a particular family of input data.

A bounding box of all transistor clusters provides a quick estimate of the net cell area,  $F_{CA}$ . The wiring cost  $F_{WL}$  can be approximated by using a standard Steiner-tree estimation procedure with optional qualifiers for special nets. For example, the routing topologies for certain nets may be known in advance from the layout architecture rules and those may be calculated separately from the other nets. The Steiner-tree estimation procedure is further described in J. M. Ho et al., "A New Approach to the Rectilinear Steiner Tree Problem," *IEEE Transactions on Computer-aided Design*, 9(2), pp. 185-193, February 1985. Before computing the number of diffusion breaks  $F_{DB}$ , the placement is compacted by abutments of adjacent clusters through diffusion sharing wherever possible.

In one embodiment, the total RV cost is represented in the following way:

$$F_{RV} = f_1(\text{electromigration}) + f_2(\text{self-heat})$$

A method of computing the electromigration cost of the total RV cost,  $f_1(\text{electromigration})$ , is now described according to one embodiment of the present

invention. The goal of the electromigration cost function is to reduce the unidirectional current density across all cut lines of the circuit. Let  $c(l,n)$  denote the fraction of average current corresponding to gate net  $n$  through the arbitrary vertical cut-line  $l$  across the circuit. The overall unidirectional current density cost is taken as

- 5 the maximum value of  $c(l,n)$ , summed across all nets for all possible cut-lines as follows:

$$F_{RV}(\text{electromigration}) = \max_l (3_n c(l,n))$$

In one embodiment, the following notation is used to obtain a polynomial expression for  $c(l,n)$ . Let  $pd_{left}(l,n)$  be the number of PMOS transistors with gate signal  $n$  on the left side of the line  $l$ , and  $pd_{right}(l,n)$  be the number on the right side of the line  $l$ . Let the corresponding numbers for the NMOS devices be  $nd_{left}(l,n)$  and  $nd_{right}(l,n)$ . Then define the total currents for each part as the following:

$$nd(n) = nd_{left}(l,n) + nd_{right}(l,n)$$

$$pd(n) = pd_{left}(l,n) + pd_{right}(l,n)$$

- 15 Then  $c(l, n)$  is be defined as the absolute value of

$$(nd_{left}(l,n)/nd(l,n) - pd_{left}(l,n)/pd(l,n)) \text{ or}$$

$$(nd_{right}(l,n)/nd(l,n) - pd_{right}(l,n)/pd(l,n))$$

- 20 This is the fractional unidirectional load on the horizontal wire segment connecting the left and right parts of the circuit. The method allows incremental calculation, which is essential in any iterative algorithm.

FIG. 15 is a diagram of a circuit segment 1500 used to illustrate an example method of computing an electromigration cost function. The following example illustrates the method of computing the electromigration cost,  $f_l(\text{electromigration})$ . The line  $l$  divides the circuit segment 1500 into a left and a right part for the following calculations. In this example, let  $pd_{left}(l,a) = 2I$ ,  $pd_{right}(l,a) = 2I$ ,  $nd_{left}(l,a) = I$ , and  $nd_{right}(l,a) = 2I$ . Hence  $nd(a) = 3I$  and  $pd(a) = 4I$ .

$$c(l,n) = \left| \frac{1}{2} - \frac{1}{3} \right| = \left| \frac{1}{2} - \frac{2}{3} \right| = \frac{1}{6}$$

In alternate embodiments, enhancements to this basic model may be made to make this model support various other factors such as the long and short metal electromigration rules, fudge factors for various rush-through currents etc.

The total RV cost  $F_{RV}$  includes the self-heating cost in addition to the electromigration cost. In one embodiment, a similar model can be applied to compute  $f_2(\text{self-heat})$ . The self-heat analysis is concerned with modeling the bidirectional currents on all segments. Unlike the unidirectional currents, the port locations on the input and output nets are needed to estimate what the various branch currents are. Port locations are points where the cell can be connected to the next level of hierarchy. A single net may have more than one port location in order to provide the higher-level router with more flexibility. All nodes on the input and output nets are considered to be port locations, one at a time, to determine the worst-case scenario. Even though the cell may be connected at multiple points, the analysis considers only one node per port, since connections at multiple nodes will reduce the currents carried by the branches anyway.

In one embodiment, the novel cost function also includes terminal blockage estimation ( $F_{TB}$ ). FIG. 16 is a diagram of transistors used to illustrate an example of terminal blockage. Consider the transistor arrangement given in (A) of FIG. 16. The transistor in the middle prevents direct connection between the metal straps on net n1. This arrangement blocks two routing tracks for routing the same net. If all other factors remain same, then the placement given in (B) of FIG. 16 is a better choice, since the net n1 can be routed using a single routing track instead of two. This problem is quite common in true 2-dimensional layouts, such as those of sequential cells. This problem can be conveniently dealt with during simulated annealing.

In an example embodiment, the terminal blocking cost  $F_{TB}$  is as follows:

- Initialize  $F_{TB} = 0$ .
- For each terminal, stretch its bounding box in the preferred routing direction till it intersects the cell boundary. Count the number of polygon intersections with other terminals on the same layer and net, and add it to  $F_{TB}$ .

Alternate embodiments having more complex definitions of terminal blockage that take into account allowed interconnect jogging, track estimations, special terminal blockage considerations power and ground signals etc. are contemplated. The terminal blocking costs is independent of the wire length cost, since it is possible

5 to use the same length of wire and block varying amounts of tracks on metal lines depending on the preferred routing direction and how the wires are laid out.

In one embodiment, the operation rearranging the clusters (block 1306 of FIG. 13) consists of three types of moves – flipping of clusters, swapping of clusters and exploration of different cluster implementations. To implement a flipping move,

10 a randomly picked cluster is flipped about the vertical axis. The potential payoffs of this move are better diffusion sharing and improved routing. To implement a swapping move, the positions of two randomly picked clusters are interchanged. In the case of a pure 1-dimensional or pseudo 2-dimensional placement, the rows do not overlap each other. Hence, in such a situation, swapping of two clusters will only

15 require insertion of blocks in isolated rows. Since the rows overlap in some embodiments of the present invention, insertion of a cluster in a row can potentially conflict with clusters in the other rows. Simple heuristics are used to resolve such conflicts by moving the interfering clusters either to the left or to the right. Besides the flipping and swapping moves, the perturbation function also explores different

20 layout implementations of the same cluster.

One embodiment of a method of placing the various layout clusters relative to each other as referred to in block 506 of FIG. 5 has been described. Although specific embodiments have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art that any arrangement which is

25 calculated to achieve the same purpose may be substituted for the specific embodiment shown. This application is intended to cover any adaptations or variations of the present invention. Therefore, it is intended that this invention be limited only by the claims and the equivalents thereof.

What is claimed is:

- 1 1. A computerized method of creating a layout for a circuit design, the method  
2 comprising:
  - 3 receiving a circuit design;
  - 4 receiving at least one layout rule based on a reliability verification constraint
  - 5 for the circuit design; and
  - 6 generating a layout for the circuit design through computer automated
  - 7 operations wherein the layout generated satisfies the at least one layout rule based on
  - 8 the reliability verification constraint received for the circuit design.
- 1 2. The computerized method of claim 1, wherein the reliability verification  
2 constraint arises from electromigration.
- 1 3. The computerized method of claim 1, wherein the reliability verification  
2 constraint arises from self-heat.
- 1 4. The computerized method of claim 1, wherein the at least one layout rule  
2 defines a maximum current for a given wire width.
- 1 5. The computerized method of claim 1, wherein the circuit design is a  
2 microprocessor circuit design.
- 1 6. The computerized method of claim 1, wherein the layout is a two-dimensional  
2 layout comprising a plurality of overlapping rows.
- 1 7. A computer automated placement method comprising:
  - 2 placing a plurality of components of an integrated circuit design in a layout for
  - 3 the integrated circuit design;
  - 4 analyzing the layout for reliability verification considerations;

5 rearranging the plurality of components to improve the reliability verification  
6 considerations; and

7 repeating the analyzing and the rearranging to further improve the reliability  
8 verification considerations.

1 8. The computer automated placement method of claim 7, wherein analyzing the  
2 layout for reliability verification considerations includes analyzing for  
3 electromigration considerations.

1 9. The computer automated placement method of claim 7, wherein analyzing the  
2 layout for reliability verification considerations includes analyzing for self heat  
3 considerations.

1 10. The computer automated placement method of claim 7, further comprising  
2 analyzing the layout for other considerations selected from the group consisting of:  
3 layout density constraints, aspect ratio constraints, and routing complexity  
4 constraints.

1 11. The computer automated placement method of claim 7, wherein placing the  
2 plurality of components is done in a two-dimensional manner with a plurality of  
3 overlapping rows.

1 12. The computer automated placement method of claim 7, wherein analyzing the  
2 layout is performed by calculating an overall unidirectional current density for the  
3 layout.

1 13. A computerized method of placing a plurality of components of an integrated  
2 circuit in a layout, the method comprising:  
3 assigning each one of a plurality of components of an integrated circuit to one  
4 of a plurality of clusters;

5 generating a layout for each one of the plurality of clusters;  
6 placing each one of the plurality of clusters in a layout for the integrated circuit  
7 wherein the placing is performed in a two-dimensional manner with a plurality of  
8 overlapping rows;  
9 analyzing the layout for the integrated circuit using a cost function having a  
10 reliability verification factor; and  
11 rearranging the layout for the integrated circuit; and  
12 repeating the analyzing and the rearranging until the cost function is  
13 minimized.

1 14. The computerized method of claim 13, wherein the reliability verification  
2 factor represents the effects of electromigration and self heat.

1 15. The computerized method of claim 13, wherein a width of each one of the  
2 plurality of overlapping rows is a multiple of a smallest one of the plurality of  
3 clusters.

1 16. The computerized method of claim 14, wherein assigning each one of the  
2 components is performed based on a lumped gate ordering style.

1 17. The computerized method of claim 14, wherein assigning each one of the  
2 components is performed based on a distributed gate ordering style.

1 18. The computerized method of claim 14, further comprising adjusting one or  
2 more of the plurality of components in one of the clusters to comply with a size  
3 constraint.

1 19. The computerized method of claim 18, wherein the adjusting is performed  
2 using device-based legging.

- 1    20. The computerized method of claim 18, wherein the adjusting is performed  
2    using stack-based legging.
- 1    21. The computerized method of claim 18, wherein the adjusting is performed  
2    using differential legging.
- 1    22. An article comprising:  
2        a computer-readable medium including instructions that when executed cause a  
3        computer to:  
4            receive a circuit design;  
5            receive at least one layout rule based on a reliability verification constraint for  
6        the circuit design; and  
7            generate a layout for the circuit design through computer automated operations  
8        wherein the layout generated satisfies the at least one layout rule based on the  
9        reliability verification constraint received for the circuit design.
- 1    23. The article of claim 22, wherein the reliability verification constraint arises  
2    from electromigration.
- 1    24. The article of claim 22, wherein the reliability verification constraint arises  
2    from self-heat.
- 1    25. The article of claim 22, wherein the layout is generated in a two dimensional  
2    manner having a plurality of overlapping rows.
- 1    26. An article comprising:  
2        a computer-readable medium including instructions that when executed cause a  
3        computer to:  
4            place a plurality of components of an integrated circuit design in a two-  
5        dimensional layout for the integrated circuit design;

6 analyze the layout for reliability verification considerations; and  
7 rearrange the components to improve the reliability verification considerations  
8 based on the analysis of the layout.

1 27. The article of claim 26, wherein the reliability verification consideration arises  
2 from electromigration.

1 28. The article of claim 26, wherein the reliability verification consideration arises  
2 from self-heat.

1 29. A computer-readable medium having computer-executable modules  
2 comprising:  
3 a cell library to maintain a plurality of logic gates and a plurality of layout  
4 rules;  
5 a schematic design tool to create a schematic of an integrated circuit using the  
6 plurality of gates maintained by the cell library;  
7 a net list tool to create a net list representation of the schematic; and  
8 a placement tool to generate a layout of the integrated circuit from the net list  
9 representation wherein the placement tool performs a reliability verification of the  
10 layout.

1 30. The computer-readable medium of claim 29 further comprising a routing tool  
2 to route wires between the plurality of logic gates in the layout.

1 31. A computerized system comprising:  
2 a computer-readable medium;  
3 a processor; and  
4 a computer-aided design program stored on the computer-readable medium and  
5 executable by the processor, the computer-aided design program comprising a

- 6 placement module to generate a layout of an integrated circuit wherein the
- 7 placement module performs a reliability verification of the layout.

### Abstract of the Disclosure

A 2-dimensional placement system and method minimize reliability concerns arising from electromigration and self-heat while at the same time achieving a high layout density. The 2-dimensional placement method also uses a placement space with rows that have non-uniform sizes and are overlapping. According to one 5 embodiment of the present invention, a computerized method of creating a layout for a circuit design includes receiving a circuit design and receiving at least one layout rule based on a reliability verification constraint for the circuit design. The computerized method further includes generating a layout for the circuit design through computer automated operations wherein the layout generated satisfies the at 10 least one layout rule based on the reliability verification constraint received for the circuit design.

I hereby certify that this paper or fee is being deposited with the United States Postal Service "Express Mail Post Office to Addressee" service under 37 C.F.R. 1.10 on the date indicated below and is addressed to the Assistant Commissioner for Patents, Attn: Box Patent Application, Washington, D. C. 20231.

"Express Mail" mailing label number E1530191347US

Date of Deposit November 1, 1994

Printed name Chris Hammond

Signature Chris Hammond



FIG. 1A



FIG. 1B



FIG. 2A



FIG. 2B



FIG. 3



FIG. 4



FIG. 5



FIG. 6

**FIG. 7A**



**FIG. 7B**



**FIG. 7C**



FIG. 7D



FIG. 7E



FIG. 7F



FIG. 7G





FIG. 8



FIG. 9



**FIG. 10A**



**FIG. 10B**



**FIG. 11A**



**FIG. 11B**



**FIG. 12A**



**FIG. 12B**



**FIG. 12C**



FIG. 13



FIG. 14



FIG. 15



\diagup STRAPS ON NET n1  
\diagdown STRAPS ON OTHER NETS

FIG. 16

SCHWEGMAN, LUNDBERG, WOESSNER & KLUTH, P.A.

## United States Patent Application

### COMBINED DECLARATION AND POWER OF ATTORNEY

As a below named inventor I hereby declare that: my residence, post office address and citizenship are as stated below next to my name; that

I verily believe I am the original, first and joint inventor of the subject matter which is claimed and for which a patent is sought on the invention entitled: **2-DIMENSIONAL PLACEMENT WITH RELIABILITY CONSTRAINTS FOR VLSI DESIGN.**

The specification of which is attached hereto.

I hereby state that I have reviewed and understand the contents of the above-identified specification, including the claims, as amended by any amendment referred to above.

I acknowledge the duty to disclose information which is material to the patentability of this application in accordance with 37 C.F.R. § 1.56 (attached hereto). I also acknowledge my duty to disclose all information known to be material to patentability which became available between a filing date of a prior application and the national or PCT international filing date in the event this is a Continuation-In-Part application in accordance with 37 C.F.R. §1.63(e).

I hereby claim foreign priority benefits under 35 U.S.C. §119(a)-(d) or 365(b) of any foreign application(s) for patent or inventor's certificate, or 365(a) of any PCT international application which designated at least one country other than the United States of America, listed below and have also identified below any foreign application for patent or inventor's certificate having a filing date before that of the application on the basis of which priority is claimed:

**No such claim for priority is being made at this time.**

I hereby claim the benefit under 35 U.S.C. § 119(e) of any United States provisional application(s) listed below:

**No such claim for priority is being made at this time.**

I hereby claim the benefit under 35 U.S.C. § 120 or 365(c) of any United States and PCT international application(s) listed below and, insofar as the subject matter of each of the claims of this application is not disclosed in the prior United States or PCT international application in the manner provided by the first paragraph of 35 U.S.C. § 112, I acknowledge the duty to disclose material information as defined in 37 C.F.R. § 1.56(a) which became available between the filing date of the prior application and the national or PCT international filing date of this application:

**No such claim for priority is being made at this time.**

I hereby appoint the following attorney(s) and/or patent agent(s) to prosecute this application and to transact all business in the Patent and Trademark Office connected herewith:

|                        |                 |                             |                 |                       |                   |
|------------------------|-----------------|-----------------------------|-----------------|-----------------------|-------------------|
| Adams, Gregory J.      | Reg. No. 44,494 | Harris, Robert J.           | Reg. No. 37,346 | Nelson, Albin J.      | Reg. No. 28,650   |
| Anglin, J. Michael     | Reg. No. 24,916 | Huebsch, Joseph C.          | Reg. No. 42,673 | Nielsen, Walter W.    | Reg. No. 25,539   |
| Arora, Suneel          | Reg. No. 42,267 | Jurkovich, Patti J.         | Reg. No. 44,813 | Oh, Allen J.          | Reg. No. 42,047   |
| Bianchi, Timothy E.    | Reg. No. 39,610 | Kalis, Janal M.             | Reg. No. 37,650 | Padys, Danny J.       | Reg. No. 35,635   |
| Billion, Richard E.    | Reg. No. 32,836 | Kaufmann, John D.           | Reg. No. 24,017 | Parker, J. Kevin      | Reg. No. 33,024   |
| Black, David W.        | Reg. No. 42,331 | Klima-Silberg, Catherine I. | Reg. No. 40,052 | Peacock, Gregg A.     | Reg. No. 45,001   |
| Brennan, Leoniede M.   | Reg. No. 35,832 | Kluth, Daniel J.            | Reg. No. 32,146 | Perdok, Monique M.    | Reg. No. 42,989   |
| Brennan, Thomas F      | Reg. No. 35,075 | Lacy, Rodney L.             | Reg. No. 41,136 | Polglaze, Daniel J.   | Reg. No. 39,801   |
| Brooks, Edward J., III | Reg. No. 40,925 | Leffert, Thomas W.          | Reg. No. 40,697 | Prout, William F.     | Reg. No. 33,995   |
| Chu, Dinh C.P.         | Reg. No. 41,676 | Lemaire, Charles A.         | Reg. No. 36,198 | Schumm, Sherry W.     | Reg. No. 39,422   |
| Clark, Barbara J.      | Reg. No. 38,107 | Litman, Mark A.             | Reg. No. 26,390 | Schwegman, Micheal L. | Reg. No. 25,816   |
| Dahl, John M.          | Reg. No. 44,639 | Lundberg, Steven W.         | Reg. No. 30,568 | Sieffert, Kent J.     | Reg. No. 41,312   |
| Drake, Eduardo E.      | Reg. No. 40,594 | Mack, Lisa K.               | Reg. No. 42,825 | Slifer, Russell D.    | Reg. No. 39,838   |
| Eliseeva, Maria M.     | Reg. No. 43,328 | Maki, Peter C.              | Reg. No. 42,832 | Smith, Michael G.     | Reg. No. P-45,368 |
| Embretson, Janet E.    | Reg. No. 39,665 | Malen, Peter L.             | Reg. No. 44,894 | Steffey, Charles E.   | Reg. No. 25,179   |
| Fogg, David N.         | Reg. No. 35,138 | Mates, Robert E.            | Reg. No. 35,271 | Terry, Kathleen R.    | Reg. No. 31,884   |
| Fordenbacher, Paul J.  | Reg. No. 42,546 | McCrackin, Ann M.           | Reg. No. 42,858 | Viksnins, Ann S.      | Reg. No. 37,748   |
| Forrest, Bradley A.    | Reg. No. 30,837 | Nama, Kash                  | Reg. No. 44,255 | Woessner, Warren D.   | Reg. No. 30,440   |

I hereby authorize them to act and rely on instructions from and communicate directly with the person/assignee/attorney/firm/organization/who/which first sends/sent this case to them and by whom/which I hereby declare that I have consented after full disclosure to be represented unless/until I instruct Schwegman, Lundberg, Woessner & Kluth, P.A. to the contrary.

Please direct all correspondence in this case to **Schwegman, Lundberg, Woessner & Kluth, P.A.** at the address indicated below:

**P.O. Box 2938, Minneapolis, MN 55402**

**Telephone No. (612)373-6900**

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon.

Full Name of joint inventor number 1 : **Kiran Ganesh**  
Citizenship: **India** Residence: **Mountain View, CA**  
Post Office Address: **302 Easy Street  
#39  
Mountain View, CA 94043**

Signature: \_\_\_\_\_ Date: \_\_\_\_\_  
**Kiran Ganesh**

Full Name of joint inventor number 2 : **Artour Levin**  
Citizenship: **Belarus** Residence: **San Jose, CA**  
Post Office Address: **1128 Wunderlich Drive  
San Jose, CA 95129**

Signature: \_\_\_\_\_ Date: \_\_\_\_\_  
**Artour Levin**

Additional inventors are being named on separately numbered sheets, attached hereto.

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon.

Full Name of joint inventor number 3 : **Miles F. McCoo**  
Citizenship: **United States of America** Residence: **Haifa, Israel**  
Post Office Address:  
Sderot Hanassi 28  
#10  
Haifa 34372  
Israel

Signature: \_\_\_\_\_ Date: \_\_\_\_\_  
Miles F. McCoo

Full Name of joint inventor number 4 : **Naresh K. Sehgal**  
Citizenship: **United States of America** Residence: **Santa Clara, CA**  
Post Office Address:  
3240 Cabrillo Avenue  
Santa Clara, CA 95051

Signature: \_\_\_\_\_ Date: \_\_\_\_\_  
Naresh K. Sehgal

Full Name of inventor:  
Citizenship: Residence:  
Post Office Address:

Signature: \_\_\_\_\_ Date: \_\_\_\_\_  
\_\_\_\_\_

Full Name of inventor:  
Citizenship: Residence:  
Post Office Address:

Signature: \_\_\_\_\_ Date: \_\_\_\_\_  
\_\_\_\_\_

